/* ═══════════════════════════════════════════════
   DryFairy — Galaxy Map
   ═══════════════════════════════════════════════ */

.sf-galaxy-wrap {
    position: relative;
    width: 100%;
    height: 100%;
}
#sf-galaxy-canvas {
    display: block;
    width: 100%;
    height: 100%;
    cursor: grab;
}
#sf-galaxy-canvas:active { cursor: grabbing; }

.sf-galaxy-tooltip {
    display: none;
    position: absolute;
    background: var(--sf-glass);
    backdrop-filter: blur(16px);
    border: 1px solid var(--sf-glass-border);
    border-radius: var(--sf-radius);
    padding: 14px 18px;
    pointer-events: none;
    z-index: 10;
    min-width: 180px;
    box-shadow: 0 8px 32px rgba(0,0,0,0.5);
    animation: sf-tooltip-in 0.15s ease-out;
}
@keyframes sf-tooltip-in { from { opacity: 0; transform: translateY(4px) scale(0.97); } to { opacity: 1; transform: translateY(0) scale(1); } }

.sf-tip-name { font-weight: 700; font-size: 16px; color: #fff; }
.sf-tip-type { font-size: 14px; color: var(--sf-text-dim); margin-top: 4px; }
.sf-tip-danger { font-size: 13px; color: var(--sf-gold); margin-top: 6px; }
.sf-tip-dist { font-size: 13px; color: var(--sf-accent); margin-top: 6px; }
.sf-tip-bodies { font-size: 13px; color: var(--sf-text); margin-top: 4px; }

.sf-galaxy-legend {
    position: absolute;
    bottom: 16px;
    left: 16px;
    background: var(--sf-glass);
    backdrop-filter: blur(12px);
    border: 1px solid var(--sf-glass-border);
    border-radius: var(--sf-radius-sm);
    padding: 10px 14px;
    display: flex;
    flex-direction: column;
    gap: 5px;
}
.sf-legend-item { font-size: 13px; display: flex; align-items: center; gap: 8px; }
.sf-legend-dot {
    width: 10px;
    height: 10px;
    border-radius: 50%;
    display: inline-block;
}

/* Onboarding Hint im Galaxy View */
.sf-galaxy-wrap > .sf-onboarding-box {
    position: absolute;
    top: 16px;
    left: 50%;
    transform: translateX(-50%);
    max-width: 480px;
    z-index: 20;
    background: rgba(20, 15, 30, 0.92);
    backdrop-filter: blur(12px);
    text-align: center;
}

.sf-galaxy-controls {
    position: absolute;
    bottom: 16px;
    right: 16px;
    display: flex;
    flex-direction: column;
    gap: 4px;
}
.sf-btn-zoom {
    width: 40px;
    height: 40px;
    background: var(--sf-glass);
    backdrop-filter: blur(12px);
    border: 1px solid var(--sf-glass-border);
    color: var(--sf-text);
    font-size: 18px;
    border-radius: var(--sf-radius-sm);
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all 0.2s;
}
.sf-btn-zoom:hover {
    border-color: var(--sf-accent);
    box-shadow: var(--sf-glow-accent);
    color: #fff;
}
