html,body{margin:0;padding:0;height:100%;overflow:hidden}body{display:flex;flex-direction:column}.map-main[data-astro-cid-qusuamwx]{flex:1;width:100%;height:100%;overflow:hidden;position:relative}.view-toggle{position:fixed;bottom:var(--space-lg);right:var(--space-lg);z-index:var(--z-dropdown);background-color:var(--color-accent);color:var(--color-surface-primary);border:none;border-radius:var(--border-radius-full);width:56px;height:56px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .3s ease;box-shadow:var(--shadow-primary)}.view-toggle:hover{background-color:var(--color-accent-hover);transform:scale(1.1);box-shadow:var(--shadow-lg)}.view-toggle:active{transform:scale(.95)}.toggle-icon svg{width:24px;height:24px;transition:transform .3s ease}.view-toggle.directory-active .toggle-icon svg{transform:rotate(90deg)}.map-view{display:none;width:100%;height:100%;position:absolute;inset:0}.map-view.active{display:block}#map{width:100%;height:100%;position:absolute;inset:0;background-color:var(--color-surface-primary)}.directory-view{display:none;width:100%;height:100%;position:absolute;inset:0;background-color:var(--color-surface-primary);overflow-y:auto}.directory-view.active{display:block}.guides-container{max-width:var(--size-max-width);margin:0 auto;padding:var(--space-lg);background-color:var(--color-surface-primary);color:var(--color-text-primary);font-family:var(--font-family-base);line-height:var(--line-height-base)}.directory-header{text-align:center;margin-bottom:var(--space-lg);padding-bottom:var(--space-md);border-bottom:2px solid var(--color-accent)}.directory-header h1{margin:0 0 var(--space-sm) 0;color:var(--color-accent);font-size:var(--font-size-3xl)}.directory-description{margin:0;color:var(--color-text-primary);font-size:var(--font-size-lg);opacity:.9}.directory-content{padding:0}.spots-list{list-style:none;margin:0;padding:0;display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:var(--space-md)}.spot-item{background-color:var(--color-surface-secondary);border:1px solid var(--color-surface-secondary);border-radius:var(--border-radius-lg);transition:all .2s ease}.spot-item:hover{border-color:var(--color-accent)}.spot-link{display:block;padding:var(--space-md);text-decoration:none;color:inherit}.spot-link h3{margin:0 0 var(--space-sm) 0;color:var(--color-accent);font-size:var(--font-size-xl);font-weight:var(--font-weight-semibold)}.spot-excerpt{margin:0 0 var(--space-sm) 0;color:var(--color-text-primary);font-size:var(--font-size-sm);line-height:var(--line-height-base);opacity:.9}.spot-meta{display:flex;align-items:center;gap:var(--space-sm);flex-wrap:wrap}.skill-levels{display:flex;gap:var(--space-xs);flex-wrap:wrap}.skill-badge{padding:var(--space-xs) var(--space-sm);border-radius:var(--border-radius-full);font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);text-transform:capitalize}.skill-beginner{background:var(--color-mint-light);color:var(--color-state-success-text)}.skill-intermediate{background:#fff3cd;color:var(--color-state-warning-text)}.skill-advanced{background:#f8d7da;color:var(--color-state-danger-text)}.wave-type{color:var(--color-text-primary);font-size:var(--font-size-sm)}@media (max-width: 768px){.view-toggle{bottom:var(--space-sm);right:var(--space-sm);width:48px;height:48px}.toggle-icon svg{width:20px;height:20px}.directory-container{padding:var(--space-md) var(--space-sm) var(--space-3xl) var(--space-sm)}.directory-header h1{font-size:var(--font-size-2xl)}.directory-description{font-size:var(--font-size-base)}.spots-list{grid-template-columns:1fr;gap:var(--space-sm)}}.marker-popup{font-family:inherit}.popup-actions{margin-top:var(--space-sm);padding-top:var(--space-sm);border-top:1px solid #febc0833;display:flex;flex-direction:column;gap:var(--space-sm)}.view-spot-link{display:inline-block;color:var(--color-surface-secondary);background-color:var(--color-accent);font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);text-decoration:none;padding:var(--space-sm) var(--space-sm);border-radius:var(--border-radius-md);text-align:center;transition:background-color .2s ease}.view-spot-link:hover{background-color:var(--color-accent-hover)}.edit-location-link{display:inline-block;color:var(--color-accent);font-size:var(--font-size-sm);text-decoration:none;padding:var(--space-xs) 0;transition:opacity .2s ease;text-align:center}.edit-location-link:hover{opacity:.7;text-decoration:underline}.coordinates{margin-top:var(--space-sm);padding:var(--space-sm);background-color:var(--bg-accent-weak);border-radius:var(--border-radius-md);font-family:var(--font-family-mono);font-size:var(--font-size-sm)}.done-dragging-btn{background-color:var(--color-accent);color:var(--color-surface-primary);border:none;padding:var(--space-sm) var(--space-sm);border-radius:var(--border-radius-md);font-weight:var(--font-weight-semibold);cursor:pointer;font-size:var(--font-size-sm);transition:background-color .2s ease}.done-dragging-btn:hover{background-color:var(--color-accent-hover)}.contribution-modal{position:fixed;top:0;left:0;width:100%;height:100%;background-color:var(--overlay-scrim);display:flex;align-items:center;justify-content:center;z-index:var(--z-overlay-max);padding:var(--space-sm)}.contribution-modal-content{background-color:var(--color-surface-secondary);border:2px solid var(--color-accent);border-radius:var(--border-radius-lg);padding:var(--space-lg);max-width:600px;width:100%;max-height:90vh;overflow-y:auto}.contribution-modal-content h2{color:var(--color-accent);margin-top:0;margin-bottom:var(--space-sm);font-size:var(--font-size-2xl)}.contribution-modal-content p{color:var(--color-text-primary);margin-bottom:var(--space-sm);opacity:.9}.contribution-modal-content ol{color:var(--color-text-primary);margin-bottom:var(--space-sm);padding-left:var(--space-md)}.contribution-modal-content li{margin-bottom:var(--space-sm);opacity:.9}.contribution-modal-content a{color:var(--color-accent);text-decoration:underline;font-weight:var(--font-weight-semibold)}.contribution-modal-content a:hover{opacity:.7}.contribution-modal-content .code-block{background-color:var(--color-surface-primary);border:1px solid var(--color-surface-secondary);border-radius:var(--border-radius-md);padding:var(--space-sm);margin:var(--space-sm) 0;font-family:var(--font-family-mono);color:var(--color-accent);font-size:var(--font-size-sm)}.close-modal-btn{background-color:var(--color-accent);color:var(--color-surface-primary);border:none;padding:var(--space-sm) var(--space-md);border-radius:var(--border-radius-md);font-weight:var(--font-weight-semibold);cursor:pointer;font-size:var(--font-size-base);margin-top:var(--space-sm);transition:background-color .2s ease}.close-modal-btn:hover{background-color:var(--color-accent-hover)}.numbered-marker-with-label{background:none;border:none}.marker-with-label{display:flex;align-items:center;gap:6px;position:relative}.marker-badge{width:28px;height:28px;background:var(--color-accent);color:var(--color-surface-primary);border-radius:var(--border-radius-full);display:flex;align-items:center;justify-content:center;font-weight:var(--font-weight-bold);font-size:var(--font-size-xs);box-shadow:var(--shadow-sm);border:2px solid var(--color-surface-primary);transition:all .2s ease;flex-shrink:0;z-index:var(--z-2)}.marker-label{background:#111a22f2;color:var(--color-accent);padding:var(--space-xs) var(--space-sm);border-radius:var(--border-radius-md);font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);white-space:nowrap;box-shadow:var(--shadow-sm);border:1px solid #febc0866;backdrop-filter:blur(4px);z-index:var(--z-1)}.marker-pointer{position:absolute;bottom:-6px;left:8px;width:0;height:0;border-left:6px solid transparent;border-right:6px solid transparent;border-top:6px solid var(--color-surface-primary);z-index:var(--z-2)}.numbered-marker-with-label:hover .marker-badge{background:var(--color-accent-hover);transform:scale(1.1)}.numbered-marker-with-label:hover .marker-label{background:#e0a60726;border-color:var(--color-accent-hover);color:var(--color-accent-hover)}@media (max-width: 768px){.marker-badge{width:24px;height:24px;font-size:var(--font-size-xs)}.marker-label{font-size:var(--font-size-xs);padding:3px 8px}.marker-pointer{bottom:-5px;left:6px;border-left:5px solid transparent;border-right:5px solid transparent;border-top:5px solid var(--color-surface-primary)}}
