body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}:root{--explorer-orange:#ff6b1a;--ocean-blue:#0077b6;--forest-teal:#2a9d8f;--summit-gold:#f4a300;--midnight-navy:#1b263b;--cloud-white:#f9fafb;--stone-grey:#7a7a7a;--primary:var(--explorer-orange);--secondary:var(--ocean-blue);--accent:var(--forest-teal);--highlight:var(--summit-gold);--text-primary:var(--midnight-navy);--text-secondary:var(--stone-grey);--background:var(--cloud-white);--font-primary:"Montserrat",Helvetica,Arial,sans-serif;--font-secondary:"Inter",Helvetica,Arial,sans-serif;--spacing-xs:4px;--spacing-sm:8px;--spacing-md:16px;--spacing-lg:24px;--spacing-xl:32px;--spacing-xxl:48px;--shadow-sm:0 2px 4px #1b263b1a;--shadow-md:0 4px 12px #1b263b26;--shadow-lg:0 8px 24px #1b263b33;--transition-fast:100ms ease;--transition-normal:150ms ease;--transition-slow:300ms ease}*{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:var(--background);color:var(--text-primary);font-family:var(--font-secondary);line-height:1.6}.App{min-height:100vh}.redirect-message{background:linear-gradient(135deg,#ff6b6b,#ee5a24);color:#fff;margin-bottom:20px;padding:20px;text-align:center}.redirect-message .message-content h3{font-size:24px;margin-bottom:10px}.redirect-message .message-content p{font-size:16px;margin-bottom:8px;opacity:.9}.coming-soon-notice{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:12px;color:#fff;margin:20px 0;padding:30px;text-align:center}.coming-soon-notice h3{font-size:28px;margin-bottom:15px}.coming-soon-notice p{font-size:18px;margin-bottom:10px;opacity:.9}.coming-soon-content{padding:40px 20px;text-align:center}.coming-soon-icon{color:#667eea;margin-bottom:20px}.coming-soon-icon svg{height:64px;width:64px}.developer-badge{background:linear-gradient(135deg,#48bb78,#38a169);border-radius:20px;color:#fff;display:inline-block;font-size:14px;font-weight:600;margin-top:10px;padding:8px 16px}.loading-container{align-items:center;display:flex;justify-content:center;min-height:400px}.loading-content{color:#4a5568;text-align:center}.loading-content h2{font-size:24px;margin-bottom:10px}.loading-content p{font-size:16px;opacity:.7}.btn{align-items:center;border:2px solid #0000;border-radius:8px;cursor:pointer;display:inline-flex;font-family:var(--font-secondary);font-size:16px;font-weight:600;gap:var(--spacing-sm);justify-content:center;max-width:320px;padding:var(--spacing-md) var(--spacing-lg);text-decoration:none;transition:var(--transition-normal);width:100%}.btn:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.btn:disabled{box-shadow:none;cursor:not-allowed;opacity:.6;transform:none}.btn-primary{background:var(--explorer-orange);border-color:var(--explorer-orange);color:var(--cloud-white)}.btn-primary:hover{background:#e55a15;border-color:#e55a15}.btn-secondary{background:var(--ocean-blue);border-color:var(--ocean-blue);color:var(--cloud-white)}.btn-secondary:hover{background:#005a8f;border-color:#005a8f}.btn-google{background:#fff;border:2px solid #e2e8f0;color:var(--text-primary)}.btn-google:hover{background:#f7fafc;border-color:#cbd5e0}.btn-apple{background:var(--midnight-navy);border:2px solid var(--midnight-navy);color:var(--cloud-white)}.btn-apple:hover{background:#2a3f5f;border-color:#2a3f5f}.btn-link{background:none;color:#667eea;font-size:14px;padding:0;text-decoration:underline}.btn-link:hover{color:#5a67d8}.home-container{background:linear-gradient(135deg,var(--ocean-blue) 0,var(--forest-teal) 100%);min-height:100vh}.hero-section{color:var(--cloud-white);padding:var(--spacing-xxl) var(--spacing-md);text-align:center}.hero-content{margin:0 auto;max-width:800px}.hero-title{color:var(--cloud-white);font-family:var(--font-primary);font-size:3.5rem;font-weight:700;margin-bottom:var(--spacing-lg);text-shadow:0 2px 4px #0000001a}.hero-subtitle{color:var(--cloud-white);font-family:var(--font-secondary);font-size:1.25rem;line-height:1.6;margin-bottom:var(--spacing-xxl);opacity:.9}.authenticated-actions,.hero-actions{align-items:center;display:flex;flex-direction:column;gap:16px}.features-section{background:var(--cloud-white);padding:var(--spacing-xxl) var(--spacing-md)}.features-section h2{color:var(--ocean-blue);font-family:var(--font-primary);font-size:2.5rem;font-weight:700;margin-bottom:var(--spacing-lg);text-align:center}.section-description{color:var(--text-secondary);font-family:var(--font-secondary);font-size:1.125rem;line-height:1.6;margin-bottom:var(--spacing-xxl);margin-left:auto;margin-right:auto;max-width:800px;text-align:center}.features-grid{grid-gap:var(--spacing-xl);display:grid;gap:var(--spacing-xl);grid-template-columns:repeat(auto-fit,minmax(300px,1fr));margin:0 auto;max-width:1200px}.feature-card{background:var(--cloud-white);border:1px solid #e2e8f0;border-radius:16px;box-shadow:var(--shadow-sm);padding:var(--spacing-xl);text-align:center;transition:var(--transition-normal)}.feature-card:hover{border-color:var(--ocean-blue);box-shadow:var(--shadow-md);transform:translateY(-8px)}.feature-icon{font-size:3rem;margin-bottom:var(--spacing-lg)}.feature-card h3{color:var(--text-primary);font-family:var(--font-primary);font-size:1.5rem;margin-bottom:var(--spacing-md)}.feature-card p{color:var(--text-secondary);font-family:var(--font-secondary);line-height:1.6}.achievements-section{background:var(--background);padding:var(--spacing-xxl) var(--spacing-md)}.achievements-section h2{color:var(--ocean-blue);font-family:var(--font-primary);font-size:2.5rem;font-weight:700;margin-bottom:var(--spacing-lg);text-align:center}.achievements-grid{grid-gap:var(--spacing-xl);display:grid;gap:var(--spacing-xl);grid-template-columns:repeat(auto-fit,minmax(300px,1fr));margin:0 auto;max-width:1200px}.achievement-card{background:var(--cloud-white);border:1px solid #e2e8f0;border-radius:16px;box-shadow:var(--shadow-sm);padding:var(--spacing-xl);text-align:center;transition:var(--transition-normal)}.achievement-card:hover{border-color:var(--summit-gold);box-shadow:var(--shadow-md);transform:translateY(-8px)}.achievement-icon{font-size:3rem;margin-bottom:var(--spacing-lg)}.achievement-card h3{color:var(--text-primary);font-family:var(--font-primary);font-size:1.5rem;margin-bottom:var(--spacing-md)}.achievement-card p{color:var(--text-secondary);font-family:var(--font-secondary);line-height:1.6}.bucket-list-section{background:var(--cloud-white);padding:var(--spacing-xxl) var(--spacing-md)}.bucket-list-section h2{color:var(--ocean-blue);font-family:var(--font-primary);font-size:2.5rem;font-weight:700;margin-bottom:var(--spacing-lg);text-align:center}.bucket-list-grid{grid-gap:var(--spacing-xl);display:grid;gap:var(--spacing-xl);grid-template-columns:repeat(auto-fit,minmax(300px,1fr));margin:0 auto;max-width:1200px}.bucket-list-card{background:var(--cloud-white);border:2px solid #e2e8f0;border-radius:16px;box-shadow:var(--shadow-sm);padding:var(--spacing-xl);text-align:center;transition:var(--transition-normal)}.bucket-list-card:hover{border-color:var(--forest-teal);box-shadow:var(--shadow-md);transform:translateY(-8px)}.bucket-list-icon{font-size:3rem;margin-bottom:var(--spacing-lg)}.bucket-list-card h3{color:var(--text-primary);font-family:var(--font-primary);font-size:1.5rem;margin-bottom:var(--spacing-md)}.bucket-list-card p{color:var(--text-secondary);font-family:var(--font-secondary);line-height:1.6}.social-section{background:var(--background);padding:var(--spacing-xxl) var(--spacing-md)}.social-section h2{color:var(--ocean-blue);font-family:var(--font-primary);font-size:2.5rem;font-weight:700;margin-bottom:var(--spacing-lg);text-align:center}.social-grid{grid-gap:var(--spacing-xl);display:grid;gap:var(--spacing-xl);grid-template-columns:repeat(auto-fit,minmax(300px,1fr));margin:0 auto;max-width:1200px}.social-card{background:var(--cloud-white);border:1px solid #e2e8f0;border-radius:16px;box-shadow:var(--shadow-sm);padding:var(--spacing-xl);text-align:center;transition:var(--transition-normal)}.social-card:hover{border-color:var(--accent);box-shadow:var(--shadow-md);transform:translateY(-8px)}.social-icon{font-size:3rem;margin-bottom:var(--spacing-lg)}.social-card h3{color:var(--text-primary);font-family:var(--font-primary);font-size:1.5rem;margin-bottom:var(--spacing-md)}.social-card p{color:var(--text-secondary);font-family:var(--font-secondary);line-height:1.6}.service-info-section{background:#f7fafc;border-top:1px solid #e2e8f0;padding:40px 20px}.service-info-section h3{color:#2d3748;font-size:1.25rem;margin-bottom:24px;text-align:center}.service-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin:0 auto;max-width:800px}.service-item{background:#fff;border:1px solid #e2e8f0;border-radius:8px;color:#4a5568;font-size:.875rem;padding:16px;word-break:break-all}.signin-container{align-items:center;background:linear-gradient(135deg,#f8fafc,#e2e8f0);display:flex;justify-content:center;min-height:100vh;padding:20px}.signin-card{background:#fff;border-radius:16px;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;max-width:400px;padding:48px;width:100%}.signin-header{margin-bottom:32px;text-align:center}.signin-header h2{color:#2d3748;font-size:2rem;font-weight:700;margin-bottom:8px}.signin-header p{color:#4a5568}.signin-options{flex-direction:column;gap:16px;margin-bottom:32px}.google-icon,.signin-options{align-items:center;display:flex}.signin-footer{text-align:center}.signin-footer p{color:#4a5568;font-size:14px;margin-bottom:16px}.error-message{background:#fed7d7;border-radius:8px;color:#c53030;font-size:14px;margin-bottom:24px;padding:12px 16px;text-align:center}.app-container{background:#f8fafc;min-height:100vh}.app-header{background:#fff;border-bottom:1px solid #e2e8f0;padding:16px 24px;position:-webkit-sticky;position:sticky;top:0;z-index:100}.header-content{align-items:center;display:flex;justify-content:space-between;margin:0 auto;max-width:1200px}.app-title{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;background-clip:text;color:#2d3748;font-size:1.5rem;font-weight:700}.app-main{margin:0 auto;max-width:1200px;padding:40px 24px}.welcome-section{margin-bottom:48px;text-align:center}.welcome-section h2{color:#2d3748;font-size:2.5rem;font-weight:700;margin-bottom:16px}.welcome-section p{color:#4a5568;font-size:1.125rem}.profile-section{margin-bottom:48px}.profile-card{background:#fff;border-radius:16px;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;padding:32px}.profile-card h3{color:#2d3748;font-size:1.5rem;font-weight:600;margin-bottom:24px}.profile-info{display:flex;flex-direction:column;gap:16px}.info-row{align-items:center;border-bottom:1px solid #f7fafc;display:flex;justify-content:space-between;padding:12px 0}.info-row:last-child{border-bottom:none}.info-label{color:#4a5568}.info-value{color:#2d3748}.stats-section{margin-bottom:48px}.stats-grid{grid-gap:24px;display:grid;gap:24px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.stat-card{background:#fff;border-radius:16px;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;padding:32px 24px;text-align:center}.stat-number{color:#667eea;font-size:3rem;font-weight:700;margin-bottom:8px}.stat-label{color:#4a5568;font-size:1rem}.coming-soon{text-align:center}.coming-soon-card{background:linear-gradient(135deg,#fef7e0,#fed7aa);border:1px solid #f6ad55;border-radius:16px;padding:40px 24px}.coming-soon-card h3{color:#c05621;font-size:1.5rem;font-weight:600;margin-bottom:16px}.coming-soon-card p{color:#9c4221;font-size:1rem;line-height:1.6}.auth-callback-container{align-items:center;background:#f8fafc;display:flex;justify-content:center;min-height:100vh;padding:20px}.auth-callback-content{max-width:400px;text-align:center}.error-state h2,.loading-state h2{color:#2d3748;font-size:1.5rem;font-weight:600;margin-bottom:16px}.error-state p,.loading-state p{color:#4a5568;margin-bottom:8px}.error-icon{font-size:4rem;margin-bottom:24px}.error-state h2{color:#c53030}.loading,.loading-state{align-items:center;display:flex;flex-direction:column;justify-content:center;padding:40px}.loading-spinner{animation:spin 1s linear infinite;border:4px solid #e2e8f0;border-radius:50%;border-top-color:#667eea;height:40px;margin-bottom:16px;width:40px}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}@media (max-width:768px){.hero-title{font-size:2.5rem}.hero-subtitle{font-size:1.125rem}.features-grid{gap:24px;grid-template-columns:1fr}.signin-card{padding:32px 24px}.header-content{flex-direction:column;gap:16px;text-align:center}.stats-grid{grid-template-columns:1fr}.info-row{align-items:flex-start;flex-direction:column;gap:4px}}.debug-section{background:#fff;border-radius:12px;box-shadow:0 4px 6px #0000000d;margin-left:auto;margin-right:auto;margin-top:60px;max-width:1200px;padding:40px 20px}.oauth-debug-container{margin:0 auto;max-width:800px}.oauth-debug-container h2{color:#2d3748;margin-bottom:24px;text-align:center}.debug-info{background:#f7fafc;border-radius:8px;margin-bottom:24px;padding:24px}.debug-info h3{color:#4a5568;font-size:18px;margin-bottom:16px}.config-item{border-bottom:1px solid #e2e8f0;margin-bottom:12px;padding:8px 0}.config-item:last-child{border-bottom:none}.debug-actions{margin-bottom:32px;text-align:center}.test-results{background:#f7fafc;border-radius:8px;padding:24px}.test-results h3{color:#4a5568;margin-bottom:20px;text-align:center}.test-item{background:#fff;border:1px solid #e2e8f0;border-radius:6px;margin-bottom:24px;padding:16px}.test-item h4{color:#2d3748;font-size:16px;margin-bottom:12px}.test-item pre{background:#2d3748;border-radius:4px;color:#e2e8f0;font-size:12px;line-height:1.4;overflow-x:auto;padding:12px}.debug-notes{background:#f0f9ff;border:1px solid #0ea5e9;border-radius:8px;margin-top:24px;padding:20px}.debug-notes h3{color:#0369a1;font-size:18px;margin-bottom:16px}.debug-notes ul{list-style-type:none;padding:0}.debug-notes li{border-bottom:1px solid #e0f2fe;margin-bottom:8px;padding:8px 0}.debug-notes li:last-child{border-bottom:none}.debug-notes strong{color:#0369a1}.debug-actions .btn{margin-bottom:10px}@media (min-width:768px){.debug-actions .btn{margin-bottom:0}}@media (max-width:768px){.debug-section{margin:40px 20px;padding:24px 16px}.oauth-debug-container h2{font-size:24px}.test-item pre{font-size:10px}}.menu-button{background:none;border:none;border-radius:6px;color:#4a5568;cursor:pointer;font-size:24px;padding:8px;transition:background-color .2s ease}.menu-button:hover{background-color:#f7fafc}.menu-overlay{align-items:flex-start;background-color:#00000080;bottom:0;display:flex;justify-content:flex-end;left:0;position:fixed;right:0;top:0;z-index:1000}.menu-content{animation:slideIn .3s ease-out;background:#fff;box-shadow:-4px 0 20px #0000001a;height:100vh;max-width:90vw;width:300px}@keyframes slideIn{0%{transform:translateX(100%)}to{transform:translateX(0)}}.menu-header{background:linear-gradient(135deg,#667eea,#764ba2);border-bottom:1px solid #e2e8f0;color:#fff;padding:24px}.user-info{align-items:center;display:flex;gap:16px}.user-avatar{border:3px solid #ffffff4d;border-radius:50%;height:48px;overflow:hidden;width:48px}.user-avatar img{height:100%;object-fit:cover;width:100%}.avatar-placeholder{align-items:center;background:#fff3;color:#fff;display:flex;font-size:20px;font-weight:600;height:100%;justify-content:center;width:100%}.user-name{font-size:18px;font-weight:600}.menu-items{padding:16px 0}.menu-item{align-items:center;background:none;border:none;color:#4a5568;cursor:pointer;display:flex;font-size:16px;gap:16px;padding:16px 24px;text-align:left;transition:background-color .2s ease;width:100%}.menu-item:hover{background-color:#f7fafc}.menu-item-icon{font-size:20px;text-align:center;width:24px}.logout-item{border-top:1px solid #e2e8f0;color:#e53e3e;margin-top:8px}.logout-item:hover{background-color:#fed7d7}.blank-content{align-items:center;display:flex;flex-direction:column;justify-content:center;min-height:60vh;padding:40px;text-align:center}.blank-content h2{color:#2d3748;font-size:32px;margin-bottom:16px}.blank-content p{color:#718096;font-size:18px;line-height:1.6;max-width:500px}.map-section{margin:0 auto;max-width:1200px;padding:20px}.map-header{margin-bottom:20px;text-align:center}.map-header h2{color:#2d3748;font-size:28px;margin-bottom:8px}.map-header p{color:#718096;font-size:16px;margin-bottom:16px}.location-update-notification{animation:slideInDown .5s ease-out;background:linear-gradient(135deg,#48bb78,#38a169);border-radius:8px;box-shadow:0 4px 12px #48bb784d;color:#fff;font-weight:600;margin-bottom:16px;padding:12px 20px}@keyframes slideInDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.map-container{box-shadow:0 8px 32px #0000001a;margin-bottom:20px;overflow:hidden;position:relative}.map-container,.map-loading{border:1px solid #e2e8f0;border-radius:12px}.map-loading{align-items:center;background:#f7fafc;display:flex;flex-direction:column;height:400px;justify-content:center}.map-loading p{color:#718096;font-size:16px;margin-top:16px}.map-error{align-items:center;background:#fed7d7;border:1px solid #feb2b2;border-radius:12px;color:#c53030;display:flex;flex-direction:column;height:400px;justify-content:center;padding:20px;text-align:center}.map-error p{font-size:16px;margin-bottom:16px}.map-error-banner{background:#fed7d7;border-bottom:1px solid #feb2b2;color:#c53030;font-size:14px;padding:8px 16px}.map-controls{gap:10px;left:10px;position:absolute;top:10px;z-index:1000}.map-control-btn,.map-controls{align-items:center;display:flex}.map-control-btn{background:#fff;border:none;border-radius:6px;box-shadow:0 2px 8px #00000026;color:#4a5568;cursor:pointer;font-size:14px;font-weight:500;gap:6px;padding:8px 12px;transition:all .2s ease}.map-control-btn:hover{background:#f7fafc;box-shadow:0 4px 12px #0003;transform:translateY(-1px)}.map-stats{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#fffffff2;border-radius:6px;box-shadow:0 2px 8px #00000026;color:#4a5568;font-size:12px;font-weight:500;padding:6px 12px}.map-info-window{max-width:200px}.map-info-window h4{color:#2d3748;font-size:16px;margin:0 0 8px}.map-info-window p{color:#4a5568;font-size:14px;line-height:1.4;margin:0 0 8px}.location-coords{margin-bottom:8px}.location-coords small{color:#718096;font-family:Monaco,Menlo,Ubuntu Mono,monospace}.location-stats small{color:#718096;font-size:12px}.location-stats{background:#f7fafc;border:1px solid #e2e8f0;border-radius:8px;justify-content:space-around;margin-top:16px;padding:16px}.location-stats,.stat-item{align-items:center;display:flex}.stat-item{flex-direction:column;gap:4px}.stat-label{color:#718096;font-size:12px;font-weight:500;letter-spacing:.5px;text-transform:uppercase}.stat-value{color:#2d3748;font-size:18px;font-weight:700}@media (max-width:768px){.map-section{padding:16px}.map-header h2{font-size:24px}.map-header p{font-size:14px}.map-controls{justify-content:center;margin-bottom:10px;position:static}.location-stats{flex-direction:column;gap:16px}.stat-item{flex-direction:row;justify-content:space-between;width:100%}}@media (max-width:480px){.map-control-btn{font-size:12px;padding:6px 10px}.map-stats{font-size:10px;padding:4px 8px}.location-update-notification{font-size:14px;padding:10px 16px}}.map-control-btn.active{background-color:#28a745;border-color:#28a745}.grid-loading{align-items:center;color:#666;display:inline-flex;font-size:.9em;margin-left:10px}.grid-overlay{pointer-events:none}.grid-overlay .square-polygon{cursor:pointer;pointer-events:auto;transition:all .2s ease}.grid-overlay .square-polygon:hover{stroke-width:2px;fill-opacity:.6}.grid-overlay .square-visited{fill-color:#4caf50}.grid-overlay .square-unvisited{fill-color:#e0e0e0}.grid-legend{background:#ffffffe6;border:1px solid #ddd;border-radius:4px;font-size:.8em;padding:8px 12px;position:absolute;right:10px;top:80px;z-index:1000}.legend-item{align-items:center;display:flex;margin:4px 0}.legend-color{border:1px solid #666;height:16px;margin-right:8px;width:16px}.legend-color.visited{background-color:#4caf50}.legend-color.unvisited{background-color:#e0e0e0}.maps-layout{display:flex;height:100vh;overflow:hidden;width:100%}.sidebar{background:#fff;border-right:1px solid #e0e0e0;display:flex;flex-direction:column;flex-shrink:0;width:400px;z-index:100}.sidebar-content{flex:1 1;overflow-y:auto;padding:20px}.map-container-wrapper{flex:1 1;overflow:hidden;position:relative}.profile-avatar-container{position:absolute;right:20px;top:20px;z-index:1000}.profile-avatar{align-items:center;background:var(--explorer-orange);border-radius:50%;box-shadow:var(--shadow-md);color:var(--cloud-white);cursor:pointer;display:flex;font-size:16px;font-weight:600;height:40px;justify-content:center;transition:var(--transition-normal);-webkit-user-select:none;user-select:none;width:40px}.profile-avatar:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px)}.profile-tooltip{background:#000c;border-radius:4px;color:#fff;font-size:14px;opacity:0;padding:8px 12px;pointer-events:none;position:absolute;right:0;top:50px;transition:all .2s ease;visibility:hidden;white-space:nowrap;z-index:1001}.profile-avatar:hover+.profile-tooltip{opacity:1;visibility:visible}.profile-name{font-weight:600;margin-bottom:2px}.profile-email{font-size:12px;opacity:.9}.profile-dropdown{animation:dropdownFadeIn .2s ease;background:#fff;border:1px solid #e0e0e0;border-radius:8px;box-shadow:0 4px 20px #00000026;overflow:hidden;position:absolute;right:0;top:50px;width:280px;z-index:1002}@keyframes dropdownFadeIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.dropdown-header{align-items:center;background:#f8f9fa;border-bottom:1px solid #e0e0e0;display:flex;padding:16px}.dropdown-avatar{align-items:center;background:var(--explorer-orange);border-radius:50%;color:var(--cloud-white);display:flex;flex-shrink:0;font-size:14px;font-weight:600;height:32px;justify-content:center;margin-right:12px;width:32px}.dropdown-info{flex:1 1;min-width:0}.dropdown-name{color:#333;font-size:16px;font-weight:600;margin-bottom:2px}.dropdown-email,.dropdown-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.dropdown-email{color:#666;font-size:14px}.dropdown-divider{background:#e0e0e0;height:1px}.dropdown-items{padding:8px 0}.dropdown-item{align-items:center;background:none;border:none;color:#333;cursor:pointer;display:flex;font-size:14px;padding:12px 16px;text-align:left;transition:background-color .2s ease;width:100%}.dropdown-item:hover{background:#f5f5f5}.dropdown-icon{font-size:16px;margin-right:12px;text-align:center;width:20px}.location-update-overlay{animation:slideDown .3s ease;background:#4caf50;border-radius:8px;box-shadow:0 2px 8px #0003;color:#fff;font-size:14px;font-weight:500;left:50%;padding:12px 20px;position:absolute;top:20px;transform:translateX(-50%);z-index:1000}@keyframes slideDown{0%{opacity:0;transform:translateX(-50%) translateY(-20px)}to{opacity:1;transform:translateX(-50%) translateY(0)}}.countries-section{width:100%}.countries-error,.countries-loading{align-items:center;display:flex;flex-direction:column;justify-content:center;padding:40px 20px;text-align:center}.countries-error .error-message{color:#666;font-size:12px;margin-top:8px}.countries-summary{border-radius:8px;cursor:pointer;margin-bottom:16px;padding:20px;transition:background-color .2s ease}.countries-summary:hover{background-color:#f8f9fa}.countries-title{color:#333;font-size:18px;font-weight:600;margin:0 0 12px}.countries-count{align-items:baseline;display:flex;margin-bottom:8px}.visited-count{color:#1a73e8;font-size:32px;font-weight:700}.count-separator{color:#666;font-size:24px;margin:0 4px}.total-count{color:#666;font-size:24px;font-weight:400}.countries-percentage{color:#666;font-size:16px;font-weight:500}.countries-header{align-items:center;background:#f8f9fa;border-bottom:1px solid #e0e0e0;display:flex;padding:16px 20px}.back-button{background:none;border:none;border-radius:4px;color:#1a73e8;cursor:pointer;font-size:14px;margin-right:12px;padding:4px 8px;transition:background-color .2s ease}.back-button:hover{background-color:#e8f0fe}.countries-header h3{color:#333;font-size:18px;font-weight:600;margin:0}.countries-list{max-height:calc(100vh - 120px);overflow-y:auto;padding:16px 0}.continent-group{margin-bottom:24px}.continent-title{border-bottom:1px solid #e0e0e0;color:#666;font-size:14px;font-weight:600;letter-spacing:.5px;margin:0;padding:0 20px 8px;text-transform:uppercase}.country-item{position:relative}.country-main{align-items:center;cursor:pointer;display:flex;justify-content:space-between;padding:12px 20px;transition:background-color .2s ease}.country-main:hover{background-color:#f5f5f5}.country-name-with-flag{align-items:center;display:flex;gap:8px}.country-name{color:#333;font-size:14px;font-weight:500}.country-check{color:#4caf50;font-size:16px;font-weight:600}.dependencies-toggle{background:none;border:none;border-radius:2px;color:#666;cursor:pointer;font-size:12px;padding:4px;position:absolute;right:40px;top:50%;transform:translateY(-50%);transition:background-color .2s ease}.dependencies-toggle:hover{background-color:#e0e0e0}.dependencies-expanded{background-color:#f8f9fa;border-left:3px solid #e0e0e0;margin-left:20px}.dependency-item{align-items:center;cursor:pointer;display:flex;justify-content:space-between;padding:8px 16px;transition:background-color .2s ease}.dependency-item:hover{background-color:#e8f0fe}.dependency-name-with-flag{align-items:center;display:flex;gap:8px}.dependency-name{color:#555;font-size:13px}.dependency-check{color:#4caf50;font-size:14px}.country-detail{padding:20px}.country-detail-header{align-items:center;border-bottom:1px solid #e0e0e0;display:flex;justify-content:space-between;margin-bottom:20px;padding-bottom:16px}.country-title-with-flag{align-items:center;display:flex;gap:12px}.country-detail-header h4{color:#333;font-size:20px;font-weight:600;margin:0}.status-visited{color:#4caf50;font-size:14px;font-weight:600}.status-unvisited{color:#666;font-size:14px}.country-info{gap:16px}.country-info,.info-item{display:flex;flex-direction:column}.info-item{gap:4px}.info-label{color:#666;font-size:12px;font-weight:600;letter-spacing:.5px;text-transform:uppercase}.info-value{color:#333;font-size:14px}.dependencies-list{display:flex;flex-direction:column;gap:8px;margin-top:8px}.dependencies-list .dependency-item{background:#fff;border:1px solid #e0e0e0;border-radius:4px;margin:0;padding:8px 12px}.dependencies-list .dependency-item:hover{background-color:#f8f9fa;border-color:#1a73e8}@media (max-width:768px){.maps-layout{flex-direction:column}.sidebar{border-bottom:1px solid #e0e0e0;border-right:none;height:40%;width:100%}.map-container-wrapper{height:60%}.profile-avatar-container{right:10px;top:10px}.profile-dropdown{width:260px}}.square-info-popup{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:14px;line-height:1.4;max-width:250px}.square-info-popup h4{border-bottom:1px solid #eee;color:#333;margin:0 0 10px;padding-bottom:5px}.square-info-row{margin-bottom:8px;padding:2px 0}.square-info-row strong{color:#555}.square-info-popup.modern{background:#fff;border:1px solid #e2e8f0;border-radius:8px;box-shadow:0 4px 12px #00000026;min-width:120px;padding:12px 16px}.square-info-popup.modern .square-name{color:#2d3748;font-size:16px;font-weight:700;line-height:1.2;margin-bottom:4px}.square-info-popup.modern .square-classification{color:#4a5568;font-size:14px;line-height:1.2;margin-bottom:4px}.square-info-popup.modern .square-size{color:#718096;font-size:14px;font-style:italic;line-height:1.2}.legend-color.ocean{background-color:#1e3a8a}.legend-color.deep_ocean{background-color:#0f172a}.legend-color.coastal_ocean{background-color:#3b82f6}.legend-color.land_containing{background-color:#22c55e}.legend-color.mixed_ocean_dominant{background-color:#8b5cf6}.legend-color.mixed_land_dominant{background-color:#fde047}
/*# sourceMappingURL=main.099f6b5d.css.map*/